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(54) Automatic configuration of a network printer 

(57) A method of configuring a peripheral device 
(30) on a network (10) without user intervention 
includes a server node (20) receiving identification data 
(130) for identifying the peripheral device on the net- 
work and, if the peripheral device is a new device (135) 
on the network or a driver for the peripheral device is not 
registered (145) on the server node, the server node 
self-installing the driver (160) for the peripheral device. 
As such, newly connected peripheral devices are auto- 
matically seen on a network and a driver for the periph- 
eral device is automatically configured on a print server 
without any user intervention. Additionally, a communi- 
cation port and queue for the device are also automati- 
cally created ( 1 75, 1 85) . Moreover. device 
configurations are dynamically and automatically 
updated (190,192,195) on the print server for consist- 
ent, accurate network information. 
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0 scription 

FIELD OF THE INVENTinM 

[0001] This invention relates in general to network 
communications and. more particularly, to enabling net- 
work peripheral devices such as printers to be automat- 
ically configured without user intervention upon 
connection to a network. 

BACKGROUND OF THF iMVFMTinM 
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[0002] Enabling a user to employ a newly added 
printer over a network is often a complex task. At an 
overview level, initial set-up in current network environ- is 
ments generally requires the creation of print queues, 
printer objects and print servers. Then, such queues, 
objects and print servers must be properly linked and 
configured. Then, to send a print job to the network 
printer, the client processor usually directs the print job 20 
to a network queue on the print server, and then the 
print server processes the job from the queue and 
sends it to the printer. 

[0003] More specifically, adding a printer to a network 
environment is. conventionally, no small task. It requires 25 
a series of installation and configuration steps that are 
generally performed either by a user or a network 
administrator or both in cooperation with each other. 
Namely, the printer requires specific configuration steps 
to be performed and parameters to be applied for sue- 30 
cessful operation on the network, as also does any 
computer (client processor) on the network that will be 
sending data to the printer. For example, typically, a 
vendor's configuration application program must be exe- 
cuted on a client computer to identify the new printer 55 
(device) to be used on the network. Once the new 
printer is identified from a list of devices presented by 
the vendor's configuration application, then the configu- 
ration application provides proper configuration param- 
eters for that new device. The configuration parameters 4o 
are very specific to the device being added and to the 
client computer and network over which communication 
occurs. 

[0004] Additionally a print server must be configured 
to enable use of the newly added printer on the network. 45 
Conventionally the print server manages and monitors 
use of the printer relative to all client computers on the 
network, and all client computers access the printer via 
the print server. Accordingly the print server must also 
be configured, in addition to the client computer, to ena- so 
ble use of the printer over the network. This includes, 
typically a vendor's configuration application also being 
executed on the print server for that printer. 
[0005] In addition to a vendor's configuration applica- 
tion being executed to install and configure the printer ss 
on the print server, the network operating system must 
also execute its configuration routines on the print 
server in order to configure and enable the printer for 



the network via the print server. This often includes 
identifying appropriate printer files, registering the 
printer with the spooling system, establishing printer 
queues and printer ports, and defining client processor 
network share-access rights to the printer. Unfortu- 
nately, the vendor configuration application and the net- 
work operating system configuration routines are 
generally not integrated, and must also be accessed 
directly from the print server itself. Thus, a network 
administrator conventionally manually initiates this soft- 
ware configuration process for the newly added printer 
from the print server itself. 

[0006] While such a conventional network printer con- 
figuration system and method works well, when prop- 
erly configured, it is more complex and cumbersome 
than what most users care to engage in. In addition, if 
the installation or configuration doesn't work quite right, 
troubleshooting can be both difficult and time-consum- 
ing. 

[0007] Accordingly, an object of the present invention 
IS to enable a peripheral device, such as a printer, to be 
automatically configured without user intervention upon 
connection to a network. 

SUMMARY OF THE INVPNTIDM 

[0008] According to principles of the present invention 
in a preferred embodiment, a method of configuring a 
peripheral device on a network without user intervention 
includes the server node receiving identification data for 
identifying the peripheral device on the network and, if 
the peripheral device is a new device on the network or 
a driver for the peripheral device is not registered on the 
server node, the server node self-installing the driver for 
the peripheral device. 

[0009] Thus, newly connected peripheral devices are 
automatically seen on a network and a driver for the 
peripheral device is automatically configured on a 
server node without any user intervention. Additionally 
a communication port and queue for the device are also 
automatically created. Moreover, device configurations 
are dynamically and automatically updated on the 
server for consistent, accurate network information. 
[0010] Other objects, advantages, and capabilities of 
the present invention will become more apparent as the 
description proceeds. 

DESCRIPTI ON OF THF r^RAWlMnQ 

[0011] 

FIG. 1 is a block diagram of a communication net- 
work and attached devices and includes the 
present invention for automatically configuring a 
network printer. 

FIGs. 2-3 are flow charts depicting a preferred 
method of the present invention. 
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DETAILED DESCRIPTION OF THE INVENTION* 

[0012] FIG. 1 is a high level block diagram of a com- 
munication network 10 and attached devices including a 
client processor 15. print server 20, DHCP server 25. 
and network printer 30. The present invention is 
described in the context of communication network 10 
being a conventional TCP/IP network. In the diagram, 
network 10 is illustrated as directional arrows to repre- 
sent the TCP/IP communication links and data flow 
paths between each of the devices over the network in 
association with the present invention. The present 
invention is further described herein in the context of cli- 
ent processor 15. print server 20 and DHCP server 25 
employing the Windows or \/Vindows NT operating 
system produced by Microsoft Corporation. However, 
the present invention is also applicable to other net- 
working environments and operating systems. Addition- 
ally, although a laser printer 30 is disclosed herein for 
purposes of discussion, it Is understood that it is merely 
exemplary and that the present invention is equally 
applicable to other network peripheral devices, Includ- 
ing ink jet printers, digital copiers, facsimile machines, 
etc. Moreover, each device 15. 20 and 25 includes a 
converttional network input/output (I/O) card for ena- 
bling communications with network 10. Printer 30 also 
includes a "conventional" network I/O card for general 
network communications purposes, but it is modified 
per the present invention as will be discussed hereafter. 
[001 3] Print server 20 includes device cache memory 
35. spooling system 40, and port monitor 42 as conven- 
tional in the art. Client processor 15 includes application 
software 45 as conventional in the art for sending a print 
job to printer 30. DHCP server 25 is a Dynamic Host 
Configuration Protocol (DHCP) server that holds 
TCP/IP configuration parameters available for printer 30 
and/or other devices to be configured on network 10. 
DHCP server 25 is shown and discussed as a device 
that is physically separate from print server 20 for clarity 
of discussion and illustration. However, DHCP server 25 
and print server 20 may be a single device having the 
separate functionalities combined therein. 
[0014] Overall, the present Invention enables printer 
30 to be automatically configured on network 10 for use 
by client processor 15 after it (the printer) Is physically 
connected to the network by a user. Specifically, "net- 
work plug and play" software 50 depicts a key compo- 
nent of the present invention and resides in a memory 
on print server 20. A coexisting "network plug and play" 
module 55 resides (as firmware) on the network I/O 
card in printer 30. Thus, the network I/O card on printer 
30 is modified from a corrventionai network I/O card in 
that it includes the "network plug and play" module 55 of 
the present invention. These software routines (50.55) 
execute and interact to enable the automatic configura- 
tion of printer 20 without any user intervention after the 
printer is connected to the network. 
[001 5] Referring now to FIGs. 2-3 (in conjunction with 
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FIG. 1), a flow chart describes the functionality and a 
preferred method of the present invention. First, 105 
(FIG. 2). printer 30 is connected to the network 10 and 
turned on. Upon power up, printer 30 (module 55) 

5 issues a DHCP request packet 110 over network 10. 
DHCP server 25 responds with a DHCP reply packet 
115 that contains the available TCP/IP configuration 
parameters for printer 30. Upon receiving those TCP/IP 
configuration parameters 120. printer 30 sets its mem- 

10 ory configuration to reflect the parameters received. 
The printer now has its TCP/IP address. 
[0016] Next, 125. module 55 of printer 30 sends a 
Sen^lce Location Protocol (SLP) reply packet using IP 
multicast over network 10. This SLP reply packet serves 

15 as an announcement that the printer is up and running 
on the network. The SLP reply packet contains informa- 
tion specific to printer 30. including the printer's hard- 
ware (network I/O card) address, TCP/IP address, 
printer model name, network I/O card name, and 

20 TCP/IP hostname. 

[0017] When "network plug and play" service 50 
receives the SLP packet data 130. it initiates a search of 
device cache 35 on print server 20 to determine 
whether printer 30 (as identified in the SLP reply packet 

25 data) is a new device on the network. If printer 30 is a 
new device 135 on the network (i.e., there Is not an 
entry for printer 30 in cache 35), then It is added as a 
new entry 140 to cache 35. Additionally, and impor- 
tantly, after adding printer 30 as a new entry to cache 

30 35, "network plug and play" service 50 then installs the 
appropriate print driver for printer 35 onto printer server 
20 based on the printer model provided in the SLP reply 
packet. 

[0018] Automatically installing the appropriate print 

35 driver includes communicating 145 (FIG. 3) with spool- 
ing system 40 to see if the appropriate print driver is 
already registered therein. If it is not, the installation 
source (location) of the network operating system is 
determined 150 (i.e., from a saved location in the Win- 

40 dows and Windows NT operating systems) and then 
that installation source (ie., local or remote disk drive) is 
accessed in an attempt to automatically obtain the print 
driver, if the original disk that was used to install the net- 
work operating system is available at the source loca- 

45 tion 155 (i.e.. in the drive), then the appropriate print 
driver for printer 30 is accessed 160 and registered with 
spooling system 40. Thus, the print driver installation is 
completely automated by "network plug and play" soft- 
ware 50. 55 of the present invention. 

50 [0019] Only if the original disk does not exist at the 
determined source location 150, 155 will a user be 
prompted for input 165 to identify the location of the 
installation disk. However, this prompting only occurs 
once because the "network plug and play" module sub- 

55 sequently stores 170 the user input source location. As 
such, upon a next attempt to install another printer, the 
newly identified installation location is automatically 
accessed for obtaining the appropriate print driver. 
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Then, only if the installation disk is not in that location 
will another prompt occur for user input to identify a new 
installation location. 

[0020] Subsequent to accessing the print driver 150. 
155, 160 and registering it with spooling system 40, 5 
"network plug and play" software 50 then creates a 
communication port 175 on print server 20 using the 
hostname from the SLP reply packet or a generated 
port name based on the hardware address of the 
device. Additionally a print queue is created 180 on io 
print server 20 using a unique name based on the 
model name of printer 30 (supplied in the SLP reply 
packet). The print queue is then designated with net- 
work share access rights 180 so client processor 15 can 
use printer 30 over network 10. 75 
[0021] Finally, after basic communication and config- 
uration parameters have been established, "network 
plug and play" software 50 then queries printer 30 for 
additional attribute information 185. such as how much 
memory the printer has. text describing the printer. 20 
number of trays, print resolution, etc. This information is 
then sent to spooling system 40 to allow client proces- 
sor 15 to locate printer 30 based on such attributes. At 
this point, client processor 15 is now able to send print 
data to printer 30 via print server 20. 25 
[0022] Referring back now for a moment to the deter- 
mination 130, 135 (FIG. 2) of whether an entry already 
exists for printer 30 in cache 35. if an entry exists (i.e.. 
the printer is not a new device on the network), then no 
change is made in cache 35. However, if some configu- 30 
ration parameters have changed 190 for printer 30 (as 
detected in the SLP reply packet information), but the 
printer model has not changed 192, then the spooler 40 
configuration parameters are adjusted accordingly 195. 
For example, if an l/P address for printer 30 has 35 
changed, then the port address in spooling system 40 is 
modified accordingly 

[0023] On the other hand, if the printer model has 
changed 192. then a determination is made 145 (FIG. 
3) as to whether the print driver for that new (changed) 40 
model is already registered in the spooler. If the driver 
for the changed model is not already registered 145, 
then steps are taken 150, 155. 180 to access and install 
the appropriate driver (as previously discussed). If the 
driver is already registered 145. then we simply ensure 45 
that a proper communication port 175 and print queue 
1 80 are created, and we verify attribute information 185. 
[0024] in either case, whether certain printer parame- 
ters are noted to have changed, or whether the printer 
model itself has changed, these processes discussed so 
for capturing the changes represent a unique, dynamic 
updating capability of the present invention for automat- 
ically maintaining accurate network information for 
printer 30 on print server 20 without any user interven- 
tion* 55 
[0025] Advantageously, the present invention enables 
new peripheral devices (such as printer 30) to be auto- 
matically seen on a network with the only user input 



requirement being to physically connect the printer to 
the network Importantly the printer driver is automati- 
cally configured on print server 20 without any user 
intervention, the port and queue for the printer are like- 
wise automatically created, and printer configurations 
are dynamically and automatically updated for consist- 
ent, accurate network information. 
[0026] In summary, the present invention provides an 
automatic configuration of a network peripheral device 
without user intervention. It will be obvious to one of 
ordinary skill in the art that the present invention is eas- 
ily implemented utilizing any of a variety of components 
and tools existing in the art. Moreover, while the present 
invention has been described by reference to specific 
embodiments, it will be apparent that other alternative 
embodiments and methods of implementation or modi- 
fication may be employed without departing from the 
true spirit and scope of the invention. 

Claims 

1 . A method of configuring a peripheral device (30) on 
a network (10) without user intervention, the net- 
work having a server node (20) connected thereto, 
the method comprising: 

(a) the server node (20) receiving identification 
data (130) for identifying the peripheral device 
(30) on the network (10); and. 

(b) upon detecting the received identification 
data, the server node self-installing a driver 
(160) for the peripheral device if the driver is 
not already installed (145) on the server node 
(20). 

2. The method of claim 1 wherein the peripheral 
device (30) is selected from a printing device, digital 
copying device, or facsimile device. 

3. The method of claim 1 or 2 wherein the step of self- 
installing the driver (160) includes accessing a 
driver file for the peripheral device and registering 
the driver file with the server node. 

4. The method of claim 3 wherein accessing the driver 
file includes accessing a storage device (150.155) 
identified from a memory location in the server 
node (20). the storage device being identified as a 
source from which the server node was network 
enabled. 

5. The method of claim 1 . 2. 3 or 4 wherein the periph- 
eral device is a printer (30) and wherein the step of 
self -installing the driver (160) includes registering 
the peripheral device with a spooling system asso- 
ciated with the server node. 

6. The method of claim 1 . 2, 3, 4 or 5 further including. 
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upon detecting the received identification ddta. the 
server node (20) self-creating a communication tine 
(175,180) to frie peripheral device. 

7. The method of claim 1. 2, 3. 4, 5 or 6 wherein the s 
Identification data is received (130) by the periph- 
eral device (30) having broadcast (125) the identifi- 
cation data over the network (10). 



8. The method of daim 1,2,3, 4. 5. 6 or 7 further io 
including the server node (20) seff-modrfying 
(190,192.195) to embody changed configuration 
parameters of the peripheral device as identified 
from the received identification data. 

15 

9. An apparatus (50,55) for configuring a peripheral 
device (30) on a network (10) without user interven- 
tion, the network having a server node (20) con- 
nected thereto, the apparatus comprising: 



(a) means (50,55) for enabling the server node 
(20) to receive identification data (130) for iden- 
tifying the peripheral device (30) on the net- 
work (10); and, 

(b) means (50,55) for enabling the server node 25 
(20) to self-Install a driver (160) for the periph- 
eral device (30) upon detecting the received 
Identification data. 

10. The apparatus of claim 9 further including means 30 
for enabling the server node (20) to self-modify 
(190,192,195) to embody changed configuration 
parameters of the peripheral device (30) as identi- 
fied from the received identification data. 
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